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Foreword 



This Technical Specification has been produced by the 3' Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 
where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 



The present document is part 1 of a multi-part TS covering the 3' Generation Partnership Project: Technical 
Specification Group Core Network; Open Service Access (OSA); Application Programming Interface (API), as 
identified below. The API specification (3GPP TS 29.198) is structured in the following Parts: 



Parti 

Part 2 
Part 3 
Part 4 
Parts 
Part 6 
Part? 
Parts 
Part 9 
Part 10 
Part 11 
Part 12 



Overview 

Common Data Definitions 

Framework 

Call Control SCF 

User Interaction SCF 

Mobility SCF 

Terminal Capabilities SCF 

Data Session Control SCF 

Generic Messaging SCF (not part of 3GPP Release 4) 

Connectivity Manager SCF (not part of 3GPP Release 4) 

Account Management SCF 

Charging SCF 



The Mapping specification of the OSA APIs and network protocols (3GPP TR 29.998) is also structured as above. 
A mapping to network protocols is however not applicable for all Parts, but the numbering of Parts is kept. 
Also in case a Part is not supported in a Release, the numbering of the parts is maintained. 



OSA API specifications 29.198-family 


OSA API Mapping - 29.998-faniily 


29.198-1 


Part 1: Overview 


29.998-1 


Part 1 : Overview 


29.198-2 


Part 2: Common Data Definitions 


29.998-2 


Not Applicable 


29.198-3 


Part 3: Framework 


29.998-3 


Not Applicable 


29.198-4 


Part 4: Call Control SCF 


29.998-4-1 


Subpart 1 : Generic Call Control - CAP mapping 


29.998-4-2 




29.198-5 


Part 5: User Interaction SCF 


29.998-5-1 


Subpart 1 : User Interaction - CAP mapping 


29.998-5-2 




29.998-5-3 




29.998-5-4 


Subpart 4: User Interaction - SMS mapping 


29.198-6 


Part 6: Mobility SCF 


29.998-6 


User Status and User Location - MAP mapping 


29.198-7 


Part 7: Terminal Capabilities SCF 


29.998-7 


Not Applicable 


29.198-8 


Part 8: Data Session Control SCF 


29.998-8 


Data Session Control - CAP mapping 


29.198-9 


Part 9: Generic Messaging SCF 


29.998-9 


Not Applicable 


29.198-10 


Part 10: Connectivity Manager SCF 


29.998-10 


Not Applicable 


29.198-11 


Part 11: Account Management SCF 


29.998-11 


Not Applicable 


29.198-12 


Part 12: Charging SCF 


29.998-12 


Not Applicable 
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The following table explains how the various releases of ETSI, Parlay and 3GPP OS A specifications correspond. Each 
ETSI and 3GPP specification carries a version number and is updated independently. The frequency of 3GPP updates 
may be up to every 3 months, which is greater than that of ETSI or Parlay, therefore, while there is a corresponding 
version of 3GPP TS 29. 198 for every version of ETSI ES 201 915 or ES 202 915, there is not necessarily a 
corresponding version of the ETSI specification for each version of the 3GPP specification. For example, there is no 
ETSI or Parlay specification version which corresponds exactly to the 3GPP issue of TS 29.198 Release 4 from 
December 2001. 

ETSI ES 201 915 / Parlay 3 / 3GPP TS 29.198 Release 4 (version 4.x.x) 



ETSI OSA Specification Set 


Parlay Phase 


3GPPTS 29.198 version 


- 


- 


Release 4, March 2001 Plenary 


- 


- 


Release 4, June 2001 Plenary 


ES201 915 V. 1.1.1 (complete release) 


Parlay 3.0 


Release 4, September 2001 Plenary 


- 


- 


Release 4, December 2001 Plenary 


ES201 915V.1.2.1 (complete release) 


Parlay 3.1 


Release 4, March 2002 Plenary 


ES201 915V.1.3.1 (complete release) 


Parlay 3.2 


Release 4, June 2002 Plenary 


- 


- 


Release 4, September 2002 Plenary 


ES201 915V.1.4.1 (complete release) 


Parlay 3.3 


Release 4, March 2003 Plenary 


- 


- 


Release 4, June 2003 Plenary 


- 


- 


Release 4, December 2003 Plenary 


- 


- 


Release 4, June 2004 Plenary 


ES 201 915 v1. 5.1 (Partial Release) 


Parlay 3.4 


Release 4, September 2004 Plenary 


- 


- 


Release 4, December 2004 Plenary 


- 


- 


Release 4, December 2005 Plenary 



ETSI ES 202 915 / Parlay 4 / 3GPP TS 29.198 Release 5 (version 5.x.x) 



ETSI OSA Specification Set 


Parlay Phase 


3GPPTS 29.198 version 


- 


- 


Release 5, March 2002 Plenary 


ES 202 915 V.I .1 .1 (complete release) 


Parlay 4.0 


Release 5, September 2002 Plenary 


ES202 915V.1.2.1 (not parts 9, 13, 14) 


Parlay 4.1 


Release 5, March 2003 Plenary 


- 


- 


Release 5, June 2003 Plenary 


- 


- 


Release 5, September 2003 Plenary 


- 


- 


Release 5, December 2003 Plenary 


- 


- 


Release 5, March 2004 Plenary 


- 


- 


Release 5, June 2004 Plenary 


ES202 915v1.3.1,(v1.2.1 for parts 9, 13, 14) 


Parlay 4.2 


Release 5, September 2004 Plenary 


- 


- 


Release 5, December 2004 Plenary 


- 


- 


Release 5, June 2005 Plenary 


- 


- 


Release 5, December 2005 Plenary 



ETSI ES 203 915 / Parlay 5 / 3GPP TS 29.198 Release 6 (version 6.x.x) 



ETSI OSA Specification Set 


Parlay Phase 


3GPPTS 29.198 version 


- 


- 


Release 6, June 2003 Plenary 


- 


- 


Release 6, December 2003 Plenary 


- 


- 


Release 6, June 2004 Plenary 


ES203 915v1.1.1 


Parlay 5.0 


Release 6, September 2004 Plenary 


- 


- 


Release 6, December 2004 Plenary 


- 


- 


Release 6, March 2005 Plenary 


- 


- 


Release 6, June 2005 Plenary 


- 


- 


Release 6, December 2005 Plenary 
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Scope 



The present document is the first part of the 3GPP Specification defining the AppHcation Programming Interface (API) 
for Open Service Access (OS A), and provides an overview of the content and structure of the various parts of this 
specification, and of the relation to other standards documents. 

The OS A-specifications define an architecture that enables service application developers to make use of network 
functionality through an open standardised interface, i.e. the OSA APIs. The concepts and the functional architecture 
for the OSA are contained in 3GPP TS 23.127 [3]. The requirements for OSA are contained in 3GPP TS 22.127 [2]. 

This specification has been defined jointly between ETSI TISPAN, 3GPP TSG CN WG5 and The Parlay Group, in co- 
operation with a number of JAIN^"^ Community member companies. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TR 21.905: "Vocabulary for 3GPP Specifications". 

[2] 3GPP TS 22. 127: "Service Requirement for the Open Services Access (OSA); Stage 1 ". 

[3] 3GPP TS 23. 127: "Virtual Home Environment (VHE) / Open Service Access (OSA); Stage 2". 

[4] Void. 

[5] 3GPP TS 22.101: "Service aspects; Service principles". 

[6] Void. 

[7] 3GPP TS 29.002: "Mobile Application Part (MAP) specification". 

[8] 3GPP TS 29.078: "Customised Applications for Mobile network Enhanced Logic (CAMEL); 

CAMEL AppUcation Part (CAP) specification". 

[9] - [26] Void. 



3 Definitions and abbreviations 

3.1 Definitions 

For the purposes of the present document, the terms and definitions given in 3GPP TS 22.101 [5] and the following 
apply. 

Applications: Services, which are designed using Service Capability Features (SCFs). 

Gateway: Synonym for Service Capability Server (SCS). From the viewpoint of appUcations, an SCS can be seen as a 
gateway to the core network. 
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HE-VASP: Home Environment Value Added Service Provider. This is a VASP that has an agreement with the Home 
Environment to provide services. 

Home Environment: responsible for overall provision of services to users. 

Local Service: A service, which can be exclusively provided in the current serving network by a Value Added Service 
Provider. 

OSA Interface: Standardised Interface used by application to access service capability features. 

Personal Service Environment (PSE): contains personalised information defining how subscribed services are 
provided and presented towards the user. The Personal Service Environment is defined in terms of one or more User 
Profiles. 

Service Capabilities: Bearers defined by parameters, and/or mechanisms needed to realise services. These are within 
networks and under network control. 

Service Capability Feature (SCF): Functionality offered by service capabilities that are accessible via the standardised 
OSA interface. 

Service Capability Server (SCS): Functional Entity providing OSA interfaces towards an application. 

Service: term used as an alternative for Service Capability Feature in this specification. 

User Interface Profile: Contains information to present the personalised user interface within the capabilities of the 
terminal and serving network. 

User Profile: This is a label identifying a combination of one user interface profile, and one user services profile. 

User Services Profile: Contains identification of subscriber services, their status and reference to service preferences. 

Value Added Service Provider: provides services other than basic telecommunications service for which additional 
charges may be incurred. 

Virtual Home Environment: A concept for personal service environment portability across network boundaries and 
between terminals. 

3.2 Abbreviations 

For the purposes of the present document, the abbreviations given in 3GPP TR 21.905 [1] and the following apply. 

API Application Programming Interface 

CAMEL Customised Application for Mobile network Enhanced Logic 

CAP CAMEL Application Part 

CSE CAMEL Service Environment 

FW Framework 

HE Home Environment 

HE-VASP Home Environment - Value Added Service Provider 

HLR Home Location Register 

INAP Intelligent Networks Application Part 

IDL Interface Description Language 

MAP Mobile Application Part 

ME Mobile Equipment 

MExE Mobile Station (Application) Execution Environment 

MS Mobile Station 

MSC Mobile Switching Centre 

OSA Open Service Access 

PLMN Public Land Mobile Network 

PSE Personal Service Environment 

SAT SIM AppHcation Tool-Kit 

SCF Service Capability Feature 

SCP Service Control Point 

SCS Service Capability Server 

SIM Subscriber Identity Module 
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SMS 

SMTP 

UE 

USIM 

VLR 

VASP 

VHE 

WAP 

WGP 

WPP 



Short Message Service 
Simple Mail Transfer Protocol 
User Equipment 

Universal Subscriber Identity Module 
Visited Location Register 
Value Added Service Provider 
Virtual Home Environment 
Wireless Application Protocol 
Wireless Gateway Proxy 
Wireless Push Proxy 
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4 Open Service Access APIs 



The OSA-specifications define an architecture that enables service application developers to make use of network 
functionality through an open standardised interface, i.e. the OSA APIs. The network functionality is describes as 
Service Capability Features (SCFs) or Services. The OSA Framework is a general component in support of Services 
(Service Capabilities) and Applications. The concepts and the functional architecture for the OSA are contained in 
3GPP TS 23.127 [3]. The requirements for OSA are contained in 3GPP TS 22.127 [2]. 

The OSA API is split into three types of interface classes, Service and Framework (FW). 

Interface classes between the Applications and the Framework (FW), that provide applications with basic 
mechanisms (e.g. Authentication ) that enable them to make use of the service capabilities in the network. 

Interface classes between Applications and SCFs, which are individual services that may be required by the 
client to enable the running of third party applications over the interface e.g. Messaging type service. 

Interface classes between the Framework (FW) and the SCFs, that provide the mechanisms necessary for a 
multi-vendor environment. 

These interfaces represent interfaces 1, 2 and 3 in Figure 1 below. The other interfaces are not yet part of the scope of 
the work. 



Enterprise 
operator 
admin tool 



Nol in the scope 
of the present API 
vensioii 




Client 
Application 




operator 
admin 



Telecom Network 



Figure 1: 

Within the OSA concept a set of Service Capability Features (SCFs) has been specified. The OSA documentation is 
structured in parts. The first Part (the present document) contains an overview, the second Part contains common data 
definitions, the third Part the Framework interfaces and the following Parts contain the description of the SCFs. 

NOTE: The terms "Service" and "Service Capability Feature" are used as alternatives for the same concept in the 
present document. In the OSA API itself the SCFs as identified in the 3GPP requirements and architecture 
are reflected as "service", in terms like serviceFactory, serviceDiscovery. 
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5 Structure of the OSA API (29.198) and Mapping 

(29.998) documents 

The Open Service Access (OSA) Application Programming Interface (API) specifications consist of two sets of 
documents: 

API specification (3GPP TS 29.198) 

The Parts of 29.198 - apart from Part 1 (the present document) and Part 2 - define the interfaces, parameters and 

state models that belong to the API specification. UML (Unified Modelling Language) is used to specify the 

interface classes. 

As such it provides a UML interface class description of the methods (API calls) supported by that interface and the 

relevant parameters and types. The interfaces are specified in IDL (Interface Description Language). 

Mapping specification of the OSA APIs and network protocols (3GPP TR 29.998) 

The Parts of 29.998 contain a possible mapping from the APIs defined in 29. 198 to various network protocols (i.e. 
MAP [7], CAP [8], etc.). It is an informative document, since this mapping is considered as implementation- / 
vendor-dependent. On the other hand this mapping will provide potential service designers with a better 
understanding of the relationship of the OSA API interface classes and the behaviour of the network associated to 
these interface classes. 

The purpose of the OSA API is to shield the complexity of the network, its protocols and specific implementation from 
the applications. This means that applications do not have to be aware of the network nodes, a Service Capability Server 
interacts with, in order to provide the SCFs to the application. The specific underlying network and its protocols are 
transparent to the application. 

The API specification (3GPP TS 29.198) is structured in the following Parts: 

29.198-1 Parti: Overview 

29. 198-2 Part 2: Common Data Definitions 

29.198-3 Part 3: Framework 

29. 198-4 Part 4: Call Control SCF 

29. 198-5 Part 5: User Interaction SCF 

29.198-6 Part 6: Mobility SCF 

29.198-7 Part 7: Terminal Capabilities SCF 

29. 198-8 Part 8: Data Session Control SCF 

29.198-9 Part 9: Generic Messaging SCF 

29.198-10 Part 10: Connectivity Manager SCF 

29.198-11 Part 11: Account Management SCF 

29.198-12 Part 12: Charging SCF 

The Mapping specification of the OSA APIs and network protocols (3GPP TR 29.998) is also structured as above. 
A mapping to network protocols is however not applicable for all Parts, but the numbering of Parts is kept. 
Also in case a Part is not supported in a Release, the numbering of the parts is maintained. 
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Structure of the Parts of 29.198 

The Parts with API specification themselves are structured as follows: 

The Sequence diagrams give the reader a practical idea of how each of the SCF is implemented. 

The Class relationships clause shows how each of the interfaces applicable to the SCF, relate to one another. 

The Interface specification clause describes in detail each of the interfaces shown within the Class diagram part. 

The State Transition Diagrams (STD) show the progression of internal processes either in the application, or 

Gateway. 

The Data definitions clauses show a detailed expansion of each of the data types associated with the methods 
within the classes. It is to be noted that some data types are used in other methods and classes and are therefore 
defined within the Common Data types part of this specification. 

IDL description of the interface (normative Annex). 

6 Methodology 

Following is a description of the methodology used for the establishment of API specification for OS A. 



6.1 Tools and Languages 



The Unified Modelling Language (UML) ( http://www.omg.org/uml/ ) is used as the means to specify class and state 
transition diagrams. 

6.2 Packaging 

A hierarchical packaging scheme is used to avoid polluting the global name space. The root is defined as: 
org.csapi 

6.3 Colours 

For clarity, class diagrams follow a certain colour scheme. Blue for application interface packages and yellow for all the 
others. 

6.4 Naming scheme 

The following naming scheme is used for documentation. 
packages 

lowercase. 

Using the domain-based naming (For example, org.csapi) 
classes, structures and types. Start with T 

TpCapitalizedWithlnternalWordsAlsoCapitalized 
Exception class: 

TpClassNameEndsWithException 
Interface. Start with Ip: 

IpThisIsAnlnterface 
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constants: 

P_UPPER_CASE_WITH_UNDERSCORES_AND_START_WITH_P 
methods: 

firstWordLowerCaseButlnternalWordsCapitalizedO 
method"s parameters 

firstWordLowerCaseButlnternalWordsCapitalized 
collections (set, array or list types) 

TpCoUectionEndsWithSet 
class/structure members 

FirstWordAndlnternalWordsCapitalized 
Spaces in-between words are not allowed. 

6.5 State Transition Diagram text and text symbols 

The descriptions of the State Transitions in the State Transition Diagrams follow the convention: 

when_this_event_is_received [guard condition is true] /do_this_action '^send_this_message 

Furthermore, text underneath a line through the middle of a State indicates an exit or entry event (normally specified 
which one). 

6.6 Exception handling and passing results 

OS A methods communicate errors in the form of exceptions. OS A methods themselves always use the return 
parameter to pass results. If no results are to be returned a void is used instead of the return parameter. In order to 
support mapping to as many languages as possible, no method out parameters are allowed. 

6.7 References 

In the interface specification whenever Interface parameters are to be passed as an in parameter, they are done so by 
reference, and the "Ref" suffix is appended to their corresponding type (e.g. IpAnlnterfaceRef aninterface), a reference 
can also be viewed as a logical indirection. 



Original type 


IN parameter declaration 




Ipl interface 


parm : IN IplnterfaceRef 





6.8 Strings and Collections 

For character strings, the String data type is used without regard to the maximum length of the string. 

For homogeneous collections of instances of a particular data type the following naming scheme is used: <datatype>Set 

6.9 Prefixes 

OSA constants and data types are defined in the global name space: org.csapi. 
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Annex A (normative): 
OMG IDL 

A.1 Tools and Languages 

The Object Management Group"s (OMG) ( http://www.omg.org/) Interface Definition Language (IDL) is used as a 
means to programmatically define the interfaces. IDL files are either generated manually from class diagrams or by 
using a UML tool. In the case IDLs are manually written and/or being corrected manually, correctness has been verified 
using a C0RBA2 (orbos/97-02-25) compliant IDL compiler, e.g. "SUN IDL Compiler 
( http://iava.sun.com/products/idk/idl/index.html) . 



A.2 Strings and Collections 



In IDL, the data type String is typedefed (see Note below) from the CORBA primitive string. This CORBA primitive is 
made up of a length and a variable array of byte. 

NOTE: A typedef is a type definition declaration in IDL. 

In OMG IDL, this maps to a sequence of the data type. A CORBA sequence is implicitly made of a length and a 
variable array of elements of the same type. 

Example 1: typedef sequence<TpSessionID> TpSessionlDSet; 

Collection types can be implemented (for example, in C++) as a structure containing an integer for the number part, 
and an array for the data part. 

Example 2: The TpAddressSet data type may be defined in C++ as: 

typedef struct { 

short number; 

TpAddress address []; 
} TpAddressSet; 

The array "address" is allocated dynamically with the exact number of required TpAddress elements based on 
"number". 



A.3 Naming space across CORBA modules 

The following shows the naming space used in this specification. 

module org { 

module csapi { 
/* The fully qualified name of the following constant is 
org: :csapi: : P_THIS_IS_AN_OSA_GLOBAL_CONST */ 
const long P_THIS_IS_AN_OSA_GLOBAL_CONST= 1999; 
// Add other OSA global constants and types here 
module fw ( 

/* no scoping required to access P_THIS_IS_AN_OSA_GLOBAL_CONST */ 
const long P_FW_CONST= P_THIS_IS_AN_OSA_GLOBAL_CONST; 

}; 

module mm ( 

// scoping required to access P_FW_CONST 
const long P_M_CONST= fw : : P_FW_CONST; 

}; 
}; 
); 
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Annex B (informative): 
Change history 



Change history 


Date 


TSG# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


Mar 2001 


CN 11 


NP-010134 


047 


-- 


CR 29.1 98: for moving TS 29.1 98 from R99 to Pel 4 (N5-01 01 58) 


3.2.0 


4.0.0 


Jun2001 


CN_12 


NP-010330 


001 




Corrections to OSA API Rel4 (Correction to IDL namespace to align 

with that of ETSI and Parlay equivalent APIs: Change 

org. open service access root namespace to org. csapi) (N5-01 0267) 


4.0.0 


4.1.0 


Sep 2001 


CN 13 


NP-0 10464 


002 


-- 


Changing references to JAIN 


4.1.0 


4.2.0 


Dec 2001 


CN 14 


NP-010594 


003 


-- 


Replace Out Parameters with Return Types 
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